//给你一个整数 n，请你判断该整数是否是 2 的幂次方。如果是，返回 true ；否则，返回 false 。 
//
// 如果存在一个整数 x 使得 n == 2x ，则认为 n 是 2 的幂次方。 
//
// 
//
// 示例 1： 
//
// 
//输入：n = 1
//输出：true
//解释：20 = 1
// 
//
// 示例 2： 
//
// 
//输入：n = 16
//输出：true
//解释：24 = 16
// 
//
// 示例 3： 
//
// 
//输入：n = 3
//输出：false
// 
//
// 示例 4： 
//
// 
//输入：n = 4
//输出：true
// 
//
// 示例 5： 
//
// 
//输入：n = 5
//输出：false
// 
//
// 
//
// 提示： 
//
// 
// -231 <= n <= 231 - 1 
// 
//
// 
//
// 进阶：你能够不使用循环/递归解决此问题吗？ 
// Related Topics 位运算 递归 数学 
// 👍 428 👎 0

package com.cute.leetcode.editor.cn;
public class PowerOfTwo {
    public static void main(String[] args) {
        Solution solution = new PowerOfTwo().new Solution();
    }
    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        /**
         * 2的幂只能有一位1，剩下全是0，统计1的个数，判断是否为1就可以了，可以使用bitCount，也可以使用循环来查找
         * 其实不用计数 n&(n-1)==0的才行
         * 也可以得到最后一位1与原始数据进行比较，相等就true   (x&-x) == x
         */
        public boolean isPowerOfTwo(int n) {
            if (n<=0) return false;
            //1. return n>0&&(n&(n-1))==0;
            return Integer.bitCount(n)==1;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}